package thread;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.LinkedBlockingQueue;

/**
 * 自己实现一个线程池
 */
class MyThreadPool{
    //1、描述一个任务，直接使用Runnable 不需要额外创建类
    //2、使用一个数据结构来组织若干个任务
    private BlockingQueue<Runnable> queue = new LinkedBlockingQueue<>();
    //3、描述一个线程 工作线程的功能就是从任务队列中执行
    static class Worker extends Thread{
        //当前线程中由若干个Worker 线程。这些线程内部都持有了上述的任务队列
        private BlockingQueue<Runnable>queue = null;

        public Worker(BlockingQueue<Runnable> queue){
            this.queue = queue;
        }

        @Override
        public void run() {
            //需要能够拿到上面的队列
            while (true){
                //循环的获取任务队列中的任务
                //这里如果队列为空，就直接阻塞，如果队列非空，就获取到里面的内容
                Runnable runnable = null;
                try {
                    runnable = queue.take();
                    runnable.run();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }

    //4、创建一个数据结构来组织若干线程
    private List<Thread> workers = new ArrayList<>();
    public MyThreadPool(int n){
        //在构造方法中创建若干个线程
        for (int i = 0; i < n; i++) {
            Worker worker = new Worker(queue);
            worker.start();
            workers.add(worker);
        }
    }

    //5、创建一个方法 能够允许程序员来放任务到线程池中
    public void submit(Runnable runnable){
        try {
            queue.put(runnable);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}
public class demo26 {
    public static void main(String[] args) {
        MyThreadPool pool = new MyThreadPool(10);
        for (int i = 0; i < 100; i++) {
            pool.submit(new Runnable() {
                @Override
                public void run() {
                    System.out.println("hello threadpool");
                }
            });
        }
    }
}
